std::literals::chrono_literals:: operator""s
|
定義済みヘッダー
<chrono>
|
||
|
constexpr
std::
chrono
::
seconds
operator "" s ( unsigned long long secs ) ; |
(1) | (C++14以降) |
|
constexpr
std::
chrono
::
duration
<
/*unspecified*/
>
operator "" s ( long double secs ) ; |
(2) | (C++14以降) |
秒を表す std::chrono::duration リテラルを形成します。
目次 |
パラメータ
| secs | - | 秒数 |
戻り値
std::chrono::duration リテラル。
実装例
constexpr std::chrono::seconds operator""s(unsigned long long s) { return std::chrono::seconds(s); } constexpr std::chrono::duration<long double> operator""s(long double s) { return std::chrono::duration<long double>(s); } |
タグ内のC++コード、C++専門用語は翻訳せず、元のフォーマットを保持しています。翻訳対象となるテキストが存在しないため、出力は入力と同一となります)
注記
この演算子は名前空間 std :: literals :: chrono_literals で宣言されています。ここで literals と chrono_literals はどちらも インライン名前空間 です。この演算子には以下の方法でアクセスできます:
- using namespace std :: literals 、
- using namespace std :: chrono_literals 、または
- using namespace std :: literals :: chrono_literals 。
さらに、名前空間 std :: chrono 内では、 using namespace literals :: chrono_literals ; というディレクティブが 標準ライブラリ によって提供されています。そのため、プログラマが using namespace std :: chrono ; を使用して chronoライブラリ のクラスにアクセスする場合、対応するリテラル演算子も同時に可視化されます。
std::string
はまた、
operator
""
s
を定義しており、型
std::string
のリテラルオブジェクトを表現しますが、これは文字列リテラルです:
10s
は10秒を表しますが、
"10"
s
は2文字の文字列です。
例
#include <chrono> #include <iostream> int main() { using namespace std::chrono_literals; std::chrono::seconds halfmin = 30s; std::cout << "Half a minute is " << halfmin.count() << " seconds" " (" << halfmin << ").\n" "A minute and a second is " << (1min + 1s).count() << " seconds.\n"; std::chrono::duration moment = 0.1s; std::cout << "A moment is " << moment.count() << " seconds" " (" << moment << ").\n" "And thrice as much is " << (moment + 0.2s).count() << " seconds.\n"; }
出力:
Half a minute is 30 seconds (30s). A minute and a second is 61 seconds. A moment is 0.1 seconds (0.1s). And thrice as much is 0.3 seconds.
関連項目
|
新しい duration を構築する
(
std::chrono::duration<Rep,Period>
の公開メンバ関数)
|